<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="100px">
      <el-form-item label="退货单编号" prop="rtCode">
        <el-input v-model="queryParams.rtCode" placeholder="请输入退货单编号" clearable @keyup.enter.native="handleQuery" />
      </el-form-item>

      <el-form-item label="销售订单编号" prop="soCode">
        <el-input v-model="queryParams.soCode" placeholder="请输入销售订单编号" clearable @keyup.enter.native="handleQuery" />
      </el-form-item>

      <el-form-item label="客户名称" prop="clientName">
        <el-input v-model="queryParams.clientName" placeholder="请输入客户名称" clearable @keyup.enter.native="handleQuery" />
      </el-form-item>

      <el-form-item label="仓库名称" prop="warehouseName">
        <el-input v-model="queryParams.warehouseName" placeholder="请输入仓库名称" clearable @keyup.enter.native="handleQuery" />
      </el-form-item>

      <el-form-item label="单据状态" prop="status">
        <el-select v-model="queryParams.status" placeholder="请选择单据状态" clearable>
          <el-option v-for="dict in dict.type.mes_order_status" :key="dict.value" :label="dict.label" :value="dict.value" />
        </el-select>
      </el-form-item>

      <el-form-item label="退货日期">
        <el-date-picker v-model="queryParams.time" style="width: 240px" value-format="yyyy-MM-dd" type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']"></el-date-picker>
      </el-form-item>

      <el-form-item>
        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <!-- <el-col :span="1.5">
        <el-button
          type="primary"
          plain
          icon="el-icon-plus"
          size="mini"
          @click="handleAdd"
          v-hasPermi="['mes:wm:rtsalse:add']"
        >新增</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="success"
          plain
          icon="el-icon-edit"
          size="mini"
          :disabled="single"
          @click="handleUpdate"
          v-hasPermi="['mes:wm:rtsalse:edit']"
        >修改</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="danger"
          plain
          icon="el-icon-delete"
          size="mini"
          :disabled="multiple"
          @click="handleDelete"
          v-hasPermi="['mes:wm:rtsalse:remove']"
        >删除</el-button>
      </el-col> -->
      <!-- <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> -->
    </el-row>

    <el-table v-loading="loading" :data="rtsalseList" @selection-change="handleSelectionChange" height="calc(100vh - 280px)">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column type="index" label="序号" align="center" width="50" />
      <el-table-column label="退货单编号" width="140px" align="center" prop="rtCode">
        <template slot-scope="scope">
          <el-button type="text" @click="handleView(scope.row)">{{ scope.row.rtCode }}</el-button>
        </template>
      </el-table-column>
      <el-table-column label="退货单名称" width="150px" align="center" prop="rtName" :show-overflow-tooltip="true" />
      <el-table-column label="销售订单编号" width="120px" align="center" prop="soCode" />
      <el-table-column label="客户名称" width="150px" align="center" prop="clientName" :show-overflow-tooltip="true" />
      <el-table-column label="仓库" align="center" prop="warehouseName" />
      <el-table-column label="库区" align="center" prop="locationName" />
      <el-table-column label="库位" align="center" prop="areaName" />
      <el-table-column label="退货日期" align="center" prop="rtDate" width="120">
        <template slot-scope="scope">
          <span>{{ parseTime(scope.row.rtDate, "{y}-{m}-{d}") }}</span>
        </template>
      </el-table-column>
      <el-table-column label="单据状态" align="center" prop="status">
        <template slot-scope="scope">
          <dict-tag :options="dict.type.mes_order_status" :value="scope.row.status" />
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" width="120px" class-name="small-padding fixed-width">
        <template slot-scope="scope">
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" v-if="scope.row.status == 'PREPARE'" v-hasPermi="['mes:wm:rtsalse:edit']">修改</el-button>
          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" v-if="scope.row.status == 'PREPARE'" v-hasPermi="['mes:wm:rtsalse:remove']">删除</el-button>
          <el-button size="mini" type="text" icon="el-icon-video-play" @click="handleExecute(scope.row)" v-if="scope.row.status == 'PREPARE'" v-hasPermi="['mes:wm:rtsalse:exec']">执行退货</el-button>
          <el-button size="mini" type="text" icon="el-icon-video-play" @click="saveToErp(scope.row)" v-if="scope.row.status == 'CONFIRMED'" v-hasPermi="['mes:k3cloud:wmRtSalse:saveToErp']">上传ERP</el-button>
          <el-button size="mini" type="text" @click="giveDataInfo(scope.row)" icon="el-icon-printer" v-if="scope.row.status != 'PREPARE'" v-hasPermi="['mes:wm:rtsalse:print']">打印退库单</el-button>
        </template>
      </el-table-column>
    </el-table>

    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList" />

    <!-- 添加或修改产品销售退货单对话框 -->
    <el-dialog :title="title" :visible.sync="open" width="960px" append-to-body>
      <el-form ref="form" :model="form" :rules="rules" label-width="100px">
        <el-row>
          <el-col :span="8">
            <el-form-item label="退货单编号" prop="rtCode">
              <el-input v-model="form.rtCode" placeholder="请输入退货单编号" />
            </el-form-item>
          </el-col>
          <el-col :span="4">
            <el-form-item label-width="80">
              <el-switch v-model="autoGenFlag" active-color="#13ce66" active-text="自动生成" @change="handleAutoGenChange(autoGenFlag)" v-if="optType != 'view' && form.status == 'PREPARE'">
              </el-switch>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="退货单名称" prop="rtName">
              <el-input v-model="form.rtName" placeholder="请输入退货单名称" />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="8">
            <el-form-item label="销售订单编号" prop="soCode">
              <el-input v-model="form.soCode" placeholder="请输入销售订单编号" />
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="客户编号" prop="clientCode">
              <el-input v-model="form.clientCode" readonly="readonly" placeholder="请输入客户编码">
                <el-button slot="append" @click="handleSelectClient" icon="el-icon-search"></el-button>
              </el-input>
            </el-form-item>
            <ClientSelectSingle ref="clientSelect" @onSelected="handleClientSelect"></ClientSelectSingle>
          </el-col>
          <el-col :span="8">
            <el-form-item label="客户名称" prop="clientName">
              <el-input v-model="form.clientName" readonly="readonly" placeholder="请输入客户名称" />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="8">
            <el-form-item label="退货日期" prop="rtDate">
              <el-date-picker clearable v-model="form.rtDate" type="date" value-format="yyyy-MM-dd" placeholder="请选择退货日期">
              </el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="退货仓库">
              <el-cascader v-model="warehouseInfo" :options="warehouseOptions" :props="warehouseProps" @change="handleWarehouseChanged">
              </el-cascader>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="单据状态" prop="status">
              <el-select v-model="form.status" disabled placeholder="请选择单据状态">
                <el-option v-for="dict in dict.type.mes_order_status" :key="dict.value" :label="dict.label" :value="dict.value"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="24">
            <el-form-item label="退货原因" prop="rtReason">
              <el-input v-model="form.rtReason" type="textarea" placeholder="请输入退货原因" />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="24">
            <el-form-item label="备注" prop="remark">
              <el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>
      <el-divider v-if="form.rtId != null" content-position="center">产品信息</el-divider>
      <el-card shadow="always" v-if="form.rtId != null" class="box-card">
        <Rtsalseline :rtId="form.rtId" :optType="optType"></Rtsalseline>
      </el-card>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="cancel" v-if="optType == 'view' || form.status != 'PREPARE'">返回</el-button>
        <el-button type="primary" @click="submitForm" v-if="form.status == 'PREPARE' && optType != 'view'">确
          定</el-button>
        <el-button @click="cancel">取 消</el-button>
      </div>
    </el-dialog>
    <ProductsalePrint v-if="opensorting" ref="productsalePrint"></ProductsalePrint>

    <!-- 产品销售退货单执行退货对话框 -->
    <el-dialog center width="30%" title="执行退货" :visible.sync="openExecuteReturn" append-to-body>
      <div>
        <el-radio-group v-model="stockInType">
          <el-radio :label="1" v-if="checkResult == 1">生成入库单</el-radio>
          <el-radio :label="2">直接入库</el-radio>
        </el-radio-group>
      </div>

      <div v-if="stockInType == 2">
        <el-form :model="stockInForm" ref="stockInFormRef" size="small" :inline="true" :rules="stockInFormRules" label-width="100px">
          <el-form-item label="仓库">
            销售入库单
          </el-form-item>
          <el-form-item label="库区" prop="locationField">
            <el-select v-model="stockInForm.locationField" placeholder="请选中库区" clearable filterable @change="handleLocationChange">
              <el-option v-for="item in locationList" :key="item.locationId" :label="item.locationName" :value="item.locationId + '-' + item.locationCode + '-' + item.locationName" />
            </el-select>
          </el-form-item>
          <el-form-item label="库位" prop="areaField">
            <el-select v-model="stockInForm.areaField" placeholder="请选中库位" clearable filterable @keyup.enter.native="handleQuery">
              <el-option v-for="item in areaList" :key="item.areaId" :label="item.areaName" :value="item.areaId + '-' + item.areaCode + '-' + item.areaName" />
            </el-select>
          </el-form-item>
        </el-form>
      </div>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="cancelHandle">取 消</el-button>
        <el-button type="primary" @click="okHandle">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
import {
  listRtsalse,
  getRtsalse,
  delRtsalse,
  addRtsalse,
  updateRtsalse,
  execute,
  execute2,
  saveToErp
} from "@/api/mes/wm/rtsalse";
import { getTotal } from "@/api/mes/wm/rtsalseline"
import Rtsalseline from "./line.vue";
import { listLocation } from "@/api/mes/wm/location"
import { listArea } from "@/api/mes/wm/area"
import ClientSelectSingle from "@/components/clientSelect/single.vue";
import ProductsalePrint from "./print/productsalePrint";
import { getTreeList } from "@/api/mes/wm/warehouse";
import { genCode } from "@/api/mes/md/rule";
export default {
  name: "Rtsalse",
  dicts: ["mes_order_status"],
  components: {
    ClientSelectSingle,
    Rtsalseline,
    ProductsalePrint,
  },
  data() {
    return {
      areaList: [],
      locationList: [],
      stockInForm: {
        locationField: null,//库区：id-code-name
        areaField: null,//库位：id-code-name
      },
      stockInFormRules: {
        locationField: [
          { required: true, message: "请选择库区", trigger: "blur" },
        ],
        areaField: [
          { required: true, message: "请选择库位", trigger: "blur" },
        ],
      },
      rtSalseId: null,
      stockInType: 1,
      openExecuteReturn: false,
      //自动生成编码
      autoGenFlag: false,
      optType: undefined,
      opensorting: false,
      warehouseInfo: [],
      warehouseOptions: [],
      warehouseProps: {
        multiple: false,
        value: "pId",
        label: "pName",
      },
      // 遮罩层
      loading: true,
      checkResult: '1',
      // 选中数组
      ids: [],
      // 非单个禁用
      single: true,
      // 非多个禁用
      multiple: true,
      // 显示搜索条件
      showSearch: true,
      // 总条数
      total: 0,
      // 产品销售退货单表格数据
      rtsalseList: [],
      // 弹出层标题
      title: "",
      // 是否显示弹出层
      open: false,
      // 查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        rtCode: null,
        rtName: null,
        soCode: null,
        clientId: null,
        clientCode: null,
        clientName: null,
        clientNick: null,
        warehouseId: null,
        warehouseCode: null,
        warehouseName: null,
        locationId: null,
        locationCode: null,
        locationName: null,
        areaId: null,
        areaCode: null,
        areaName: null,
        rtDate: null,
        rtReason: null,
        status: null,
        attr1: null,
        attr2: null,
        attr3: null,
        attr4: null,
      },
      // 表单参数
      form: {},
      // 表单校验
      rules: {
        rtCode: [
          { required: true, message: "退货单编号不能为空", trigger: "blur" },
        ],
        rtName: [
          { required: true, message: "退货单名称不能为空", trigger: "blur" },
        ],
        rtDate: [
          { required: true, message: "请选择退货日期", trigger: "blur" },
        ],
        clientName: [
          { required: true, message: "请选择客户", trigger: "blur" },
        ],
        rtReason: [
          { required: true, message: "请填写退货原因", trigger: "blur" },
        ],
      },
    };
  },
  created() {
    this.getList();
    this.getSalseReturnWarehouseLocationList();
    this.getWarehouseList();
  },
  methods: {
    //回写erp
    saveToErp(row) {
      console.log(row);
      this.loading = true
      let rtId = row.rtId
      saveToErp(rtId).then(msg => {
        console.log(msg);
        if (msg.code == 200) {
          this.$message.success("操作成功！");
          this.getList();
          this.loading = false
        } else {
          this.loading = false
        }
      })
    },
    handleLocationChange() {
      console.log("this.stockInForm.locationField", this.stockInForm.locationField)
      let locationId = this.stockInForm.locationField.split("-")[0];
      listArea({ locationId: locationId }).then((response) => {
        if (response.code == 200) {
          this.areaList = response.rows;
        } else {
          this.$message.error(response.message);
        }
      });
    },
    //获取销售退货仓库库区列表
    getSalseReturnWarehouseLocationList() {
      listLocation({ warehouseId: 2097, pageSize: 999 }).then((response) => {
        if (response.code == 200) {
          this.locationList = response.rows;
        } else {
          this.$message.error(response.message);
        }
      });
    },
    cancelHandle() {
      this.stockInForm.locationField = null;
      this.stockInForm.areaField = null;
      this.stockInType = null;
      this.openExecuteReturn = false;
    },
    okHandle() {
      console.log(this.stockInForm)
      if (!this.stockInType) {
        this.$message.error("请选择入库类型");
        return;
      }
      debugger
      if (this.stockInType == '2') {
        this.$refs.stockInFormRef.validate((valid) => {
          if (valid) {
            execute2({
              rtId: this.rtSalseId,
              locationField: this.stockInForm.locationField,
              areaField: this.stockInForm.areaField,
              operType: this.stockInType
            }
            ).then((response) => {
              if (response.code == 200) {
                this.$message({
                  type: "success",
                  message: "执行成功",
                });
                this.openExecuteReturn = false;
                this.cancelHandle();
                this.getList();
              } else {
                this.$message.error(response.message);
              }
            })
          }
        });
      } else {
        execute2({
          rtId: this.rtSalseId,
          operType: this.stockInType
        }
        ).then((response) => {
          if (response.code == 200) {
            this.$message({
              type: "success",
              message: "执行成功",
            });
            this.cancelHandle();
            this.openExecuteReturn = false;
            this.getList();
          } else {
            this.$message.error(response.message);
          }
        })
      }

    },
    giveDataInfo(row) {
      this.opensorting = true;
      this.$nextTick(() => {
        this.$refs.productsalePrint.init(row);
      });
      console.info("row.salseId", row.salseId);
    },
    /** 查询产品销售退货单列表 */
    getList() {
      this.loading = true;
      listRtsalse(this.queryParams).then((response) => {
        this.rtsalseList = response.rows;
        this.total = response.total;
        this.loading = false;
      });
    },
    getWarehouseList() {
      getTreeList().then((response) => {
        if (response.data) {
          this.warehouseOptions = response.data.filter((el) => {
            return el.warehouseCode.indexOf("VIR") == -1;
          });
        }
        this.warehouseOptions.map((w) => {
          w.children.map((l) => {
            let lstr = JSON.stringify(l.children)
              .replace(/locationId/g, "lId")
              .replace(/areaId/g, "pId")
              .replace(/areaName/g, "pName");
            l.children = JSON.parse(lstr);
          });

          let wstr = JSON.stringify(w.children)
            .replace(/warehouseId/g, "wId")
            .replace(/locationId/g, "pId")
            .replace(/locationName/g, "pName");
          w.children = JSON.parse(wstr);
        });
        let ostr = JSON.stringify(this.warehouseOptions)
          .replace(/warehouseId/g, "pId")
          .replace(/warehouseName/g, "pName");
        this.warehouseOptions = JSON.parse(ostr);
      });
    },
    //选择默认的仓库、库区、库位
    handleWarehouseChanged(obj) {
      if (obj != null) {
        this.form.warehouseId = obj[0];
        this.form.locationId = obj[1];
        this.form.areaId = obj[2];
      }
    },
    // 取消按钮
    cancel() {
      this.open = false;
      this.reset();
    },
    // 表单重置
    reset() {
      this.form = {
        rtId: null,
        rtCode: null,
        rtName: null,
        soCode: null,
        clientId: null,
        clientCode: null,
        clientName: null,
        clientNick: null,
        warehouseId: null,
        warehouseCode: null,
        warehouseName: null,
        locationId: null,
        locationCode: null,
        locationName: null,
        areaId: null,
        areaCode: null,
        areaName: null,
        rtDate: new Date(),
        rtReason: null,
        status: "PREPARE",
        remark: null,
        attr1: null,
        attr2: null,
        attr3: null,
        attr4: null,
        createBy: null,
        createTime: null,
        updateBy: null,
        updateTime: null,
      };
      this.autoGenFlag = false;
      this.resetForm("form");
    },
    /** 搜索按钮操作 */
    handleQuery() {
      if (this.queryParams.time) {
        this.queryParams["rtDateBegin"] = this.queryParams.time[0];
        this.queryParams["rtDateEnd"] = this.queryParams.time[1];
      } else {
        this.queryParams["rtDateBegin"] = null;
        this.queryParams["rtDateEnd"] = null;
      }
      this.queryParams.pageNum = 1;
      this.getList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.queryParams.time = null;
      this.resetForm("queryForm");
      this.handleQuery();
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.ids = selection.map((item) => item.rtId);
      this.single = selection.length !== 1;
      this.multiple = !selection.length;
    },
    //客户选择事件
    handleSelectClient() {
      this.$refs.clientSelect.showFlag = true;
    },
    //客户选择
    handleClientSelect(obj) {
      if (obj != undefined && obj != null) {
        this.form.clientId = obj.clientId;
        this.form.clientCode = obj.clientCode;
        this.form.clientName = obj.clientName;
      }
    },
    /** 新增按钮操作 */
    handleAdd() {
      this.reset();
      this.open = true;
      this.title = "添加产品销售退货单";
      this.optType = "add";
    },
    // 查询明细按钮操作
    handleView(row) {
      this.reset();
      const rtIds = row.rtId;
      getRtsalse(rtIds).then((response) => {
        this.form = response.data;
        this.warehouseInfo[0] = response.data.warehouseId;
        this.warehouseInfo[1] = response.data.locationId;
        this.warehouseInfo[2] = response.data.areaId;
        this.open = true;
        this.title = "查看销售退货单信息";
        this.optType = "view";
      });
    },
    //执行入库
    async handleExecute(row) {
      console.log("row", row);
      const rtIds = row.rtId || this.ids;

      try {
        const total = await getTotal(rtIds); // 等待 getTotal 返回结果
        if (total) {
          this.$message({
            showClose: true,
            message: '退货明细中的仓库不能为空，请确认！',
            type: 'warning'
          });
          return;
        }

        //如果是从退货通知单过来的，弹出对话框
        if (row.rtReason == '退货通知单退货') {
          this.checkResult = row.checkResult;
          if (this.checkResult == 0) {
            this.stockInType = 2;
          }
          this.openExecuteReturn = true;
          this.rtSalseId = rtIds;
        } else {
          this.$modal
            .confirm("确认执行退货？")
            .then(() => execute(rtIds)) // 执行退货
            .then(() => {
              this.getList();
              this.$modal.msgSuccess("退货成功");
            })
            .catch(() => { });
        }
      } catch (error) {
        console.error("获取 total 失败:", error);
      }
    },

    /** 修改按钮操作 */
    handleUpdate(row) {
      this.reset();
      const rtId = row.rtId || this.ids;
      getRtsalse(rtId).then((response) => {
        this.form = response.data;
        this.warehouseInfo[0] = response.data.warehouseId;
        this.warehouseInfo[1] = response.data.locationId;
        this.warehouseInfo[2] = response.data.areaId;
        this.open = true;
        this.title = "修改销售退货单";
        this.optType = "add";
      });
    },
    /** 提交按钮 */
    submitForm() {
      this.$refs["form"].validate((valid) => {
        if (valid) {
          if (this.form.rtId != null) {
            updateRtsalse(this.form).then((response) => {
              this.$modal.msgSuccess("修改成功");
              this.open = false;
              this.getList();
            });
          } else {
            addRtsalse(this.form).then((response) => {
              this.$modal.msgSuccess("新增成功");
              this.open = false;
              this.getList();
            });
          }
        }
      });
    },
    /** 删除按钮操作 */
    handleDelete(row) {
      const rtIds = row.rtId || this.ids;
      this.$modal
        .confirm('是否确认删除产品销售退货单编号为"' + rtIds + '"的数据项？')
        .then(function () {
          return delRtsalse(rtIds);
        })
        .then(() => {
          this.getList();
          this.$modal.msgSuccess("删除成功");
        })
        .catch(() => { });
    },
    /** 导出按钮操作 */
    handleExport() {
      this.download(
        "wm/rtsalse/export",
        {
          ...this.queryParams,
        },
        `rtsalse_${new Date().getTime()}.xlsx`
      );
    },
    //自动生成编码
    handleAutoGenChange(autoGenFlag) {
      if (autoGenFlag) {
        genCode("RTSALSE_CODE").then((response) => {
          this.form.rtCode = response;
        });
      } else {
        this.form.rtCode = null;
      }
    },
  },
};
</script>
